<script setup lang="ts">
import EvaluateCard from './EvaluateCard.vue'
import { IllnessTime, PrescriptionStatus } from '@/enums'
import { flagOptions, timeOptions } from '@/services/constants'

import type { Message, Prescription } from '@/types/room'

import type { Image } from '@/types/consult'

import { showImagePreview, showToast } from 'vant'

import { MsgType } from '@/enums'

import { useUserStore } from '@/stores'

import { viewPrescription } from '@/composable'

import { useRouter } from 'vue-router'

const router = useRouter()

const { onShowPrescription } = viewPrescription()

const store = useUserStore()

defineProps<{ list: Message[]; loading: boolean }>()

const emit = defineEmits<{
  (e: 'refresh'): void
}>()

const getIllnessTimeText = (time: IllnessTime) =>
  timeOptions.find((item) => item.value === time)?.label

const getConsultFlagText = (flag: 0 | 1) =>
  flagOptions.find((item) => item.value === flag)?.label

const previewImg = (pictures?: Image[]) => {
  if (pictures && pictures.length)
    showImagePreview({
      images: pictures.map((item) => item.url)
    })
}
import dayjs from 'dayjs'

const formatTime = (time: string) => dayjs(time).format('HH:mm')

const buy = (prescription: Prescription) => {
  if (prescription.status === PrescriptionStatus.Invalid)
    return showToast('处方已失效')
  if (
    prescription.status === PrescriptionStatus.NotPayment &&
    !prescription.orderId
  )
    return router.push(`/order/pay?id=${prescription.id}`)
  router.push(`/order/${prescription.orderId}`)
}
</script>

<template>
  <van-pull-refresh :modelValue="loading" @refresh="emit('refresh')">
    <div
      class="msg-continer"
      v-for="{ msgType, msg, createTime, from, id, toAvatar } in list"
      :key="id"
    >
      <!-- 病情描述 -->
      <div class="msg msg-illness" v-if="msgType === MsgType.CardPat">
        <div class="patient van-hairline--bottom" v-if="msg.consultRecord">
          <p>
            {{ msg.consultRecord.patientInfo.name }}
            {{ msg.consultRecord.patientInfo.genderValue }}
            {{ msg.consultRecord.patientInfo.age }}岁
          </p>
          <p>
            {{ getIllnessTimeText(msg.consultRecord.illnessTime) }} |
            {{ getConsultFlagText(msg.consultRecord.consultFlag) }}
          </p>
        </div>
        <van-row>
          <van-col span="6">病情描述</van-col>
          <van-col span="18">{{ msg.consultRecord?.illnessDesc }}</van-col>
          <van-col span="6">图片</van-col>
          <van-col span="18" @click="previewImg(msg.consultRecord?.pictures)">
            点击查看
          </van-col>
        </van-row>
      </div>
      <!-- 温馨提示 -->
      <div class="msg msg-tip" v-if="msgType === MsgType.NotifyTip">
        <div class="content">
          <span class="green">温馨提示：</span>
          <span>{{ msg.content }}</span>
        </div>
      </div>
      <!-- 通用通知 -->
      <div class="msg msg-tip" v-if="msgType === 31">
        <div class="content">
          <span>{{ msg.content }}</span>
        </div>
      </div>
      <!-- 我发的消息 -->
      <div
        class="msg msg-to"
        v-if="msgType === MsgType.MsgText && store.user?.id === from"
      >
        <div class="content">
          <div class="time">{{ formatTime(createTime) }}</div>
          <div class="pao">{{ msg.content }}</div>
        </div>
        <van-image :src="store.user?.avatar" />
      </div>
      <!-- 医生发的消息 -->
      <div
        class="msg msg-from"
        v-if="msgType === MsgType.MsgText && store.user?.id !== from"
      >
        <van-image :src="toAvatar" />
        <div class="content">
          <div class="time">{{ formatTime(createTime) }}</div>
          <div class="pao">{{ msg.content }}</div>
        </div>
      </div>

      <!-- 我发的图片 -->
      <div
        class="msg msg-to"
        v-if="msgType === MsgType.MsgImage && store.user?.id === from"
      >
        <div class="content">
          <div class="time">{{ formatTime(createTime) }}</div>
          <van-image fit="contain" :src="msg.picture?.url" />
        </div>
        <van-image :src="store.user?.avatar" />
      </div>
      <!-- 医生发的图片 -->
      <div
        class="msg msg-from"
        v-if="msgType === MsgType.MsgImage && store.user?.id !== from"
      >
        <van-image :src="toAvatar" />
        <div class="content">
          <div class="time">{{ formatTime(createTime) }}</div>
          <van-image fit="contain" :src="msg.picture?.url" />
        </div>
      </div>

      <!-- 处方 -->
      <div class="msg msg-recipe" v-if="msgType === MsgType.CardPre">
        <div class="content" v-if="msg.prescription">
          <div class="head van-hairline--bottom">
            <div class="head-tit">
              <h3>电子处方</h3>
              <p @click="onShowPrescription(msg.prescription?.id)">
                原始处方 <van-icon name="arrow"></van-icon>
              </p>
            </div>
            <p>
              {{ msg.prescription.name }}
              {{ msg.prescription.genderValue }}
              {{ msg.prescription.age }}岁
              {{ msg.prescription.diagnosis }}
            </p>
            <p>开方时间：{{ msg.prescription.createTime }}</p>
          </div>
          <div class="body">
            <div
              class="body-item"
              v-for="med in msg.prescription.medicines"
              :key="med.id"
            >
              <div class="durg">
                <p>{{ med.name }} {{ med.specs }}</p>
                <p>{{ med.usageDosag }}</p>
              </div>
              <div class="num">x{{ med.quantity }}</div>
            </div>
          </div>
          <div class="foot">
            <span @click="buy(msg.prescription)">
              {{ msg.prescription.orderId ? '查看详情' : '购买药品' }}
            </span>
          </div>
        </div>
      </div>

      <!-- 结束问诊消息： -->
      <div
        class="msg msg-tip msg-tip-cancel"
        v-if="msgType === MsgType.NotifyCancel"
      >
        <div class="content">
          <span>{{ msg.content }}</span>
        </div>
      </div>

      <!-- 评价 -->
      <div
        class="msg msg-comment"
        v-if="msgType === MsgType.CardEva || msgType === MsgType.CardEvaForm"
      >
        <evaluate-card :evaluateDoc="msg.evaluateDoc" />
      </div>
    </div>
  </van-pull-refresh>
</template>

<style lang="scss" scoped>
@import '@/styles/room.scss';
</style>
